草庐IT

c++ - QMap 和 std::unique_ptr

全部标签

c++ - 如何使用 `std::error_category` 和 system_error header 中的其他内容?

C++中已经有足够多的错误处理策略。我们有异常处理、错误返回代码和这个ERRNO困惑。system_errorheader在这里扮演什么角色?我如何使用那里的功能?对我来说,它看起来只是随意组合在一起。我正在使用cppreference网站作为引用。 最佳答案 您可以throw和catch它作为一个正常的异常(exception)。它只是std::exception的一部分等级制度。std::system_error延伸std::runtime_error延伸std::exception应该什么时候使用?通常它用于将C风格的ERRN

c++ - std::vector push_back() 语义

我知道std::vector中的push_back在末尾放置了作为参数传递的对象的拷贝。让我们考虑这个简单的例子classFoo{public:Foo(inti=-1):i_(i){std::cout还有这段代码voidtestObjects(){std::vectorvFoo;for(inti=0;i我得到的结果是:Foo:100FoocopyCTOR:100i=0vectorsize=1~Foo:100Foo:101FoocopyCTOR:100FoocopyCTOR:101~Foo:100i=1vectorsize=2~Foo:101Foo:102FoocopyCTOR:100F

c++ - Visual Studio 2013 C++ - 将 std::unique_ptr 传递给绑定(bind)函数

使用VisualStudio2013RC和C++,我尝试将std::unique_ptr传递给已使用std::bind绑定(bind)的函数。但是,我遇到了麻烦,因为当我尝试这个时VS似乎不喜欢它。这是我要编译的内容:#include#include#includevoidfunc(std::unique_ptrarg){std::cout)>bound=std::bind(&func,std::placeholders::_1);std::unique_ptrptr(newint(42));bound(std::move(ptr));return0;}这可以在GCC4.8.1中编译,

c++ - 在 C/C++ 中定义一个全局标签

我只是想定义一个全局标签,指向a.c文件中的一行代码,然后b.c文件可以识别该标签。这两个文件都链接在一起。问题是b.c文件无法识别它,因为编译器/链接器认为a.c文件中的标签是文件特定的。我在这里找到了类似的问题和答案:UselabelinAssemblyfromC但我想在C/C++中而不是在汇编中定义一个全局标签。附言,我没有使用goto语句:) 最佳答案 根据C++标准标签的范围是它出现的功能。 关于c++-在C/C++中定义一个全局标签,我们在StackOverflow上找到一个

c++ - 为什么将此代码编译为 C 和 C++ 代码会生成不同的程序集?

我写了下面的代码:intmain(){inti;intarr[4];for(i=0;i将其保存在两个文件中:test.c和test.cpp我运行以下命令:gcc-O0test.cobjdump-Mintel-da.out>decompilecg++-O0test.cppobjdump-Mintel-da.out>decompilecpp我编辑了decompilec和decompilecpp以仅包含主要功能。现在,我运行diffdecompilecdecompilecpp并得到以下输出:12,21c12,1980483fe:0f9ec0setleal>8048401:84c0testal

c++ - 具有复数的任意精度线性代数 c/c++ 库

我正在进行一项研究,涉及4维相空间中具有复数系数的线性微分方程。为了能够检查关于解的根的一些假设,我需要能够以任意精度在数值上求解这些方程。我曾经使用mpmathPython模块,但它运行缓慢,所以我更喜欢用C/C++重写我的程序以获得最大性能。所以我有一个问题:是否存在同时支持任意精度算术和复数的C/C++线性代数库?我需要一些基本功能,如点积等。(其实我也需要矩阵指数,但如果有需要我可以自己实现)。我尝试使用Eigen与MPFRC++,但由于它不支持复数这一事实而失败(并且像complex这样的构造不起作用,因为它假定基本类型是标准float)。 最佳答

c++ - 可变数量的参数

我有几个关于可变数量参数的问题:为什么va_start、va_arg和va_end定义为宏而不是函数?va_start是如何工作的?它是否有权访问函数调用堆栈并遍历堆栈直到找到最后指定的参数? 最佳答案 RationaleforInternationalStandard—ProgrammingLanguages—C中介绍了为什么它们是宏的基本原理。在7.15Variablearguments部分说:va_startandva_argmustexistasmacros,sinceva_startusesanargumentthatis

c++ - 在一个循环中证明内存访问

我有以下功能:voidikj(float(*a)[N],float(*b)[N],float(*c)[N],intn){inti,j,k;floatr;papi_start();for(i=0;i我正在使用PAPI来计算在papi_start()和papi_stop()之间我有多少加载和存储以及结果我有以下内容:加载(使用PAPI_LD_INS):322678164205053128160607725612714815512101189551102480740695020486450848188商店(使用PAPI_SR_INS):3282906465698128524578256419

c++ - 与库的 c 绑定(bind)链接

我正在尝试链接到下一个库:(seedocs)它是一个C绑定(bind),用于用C++编写的库。但是如果制作静态库然后尝试链接到它。我收到这些消息:uchardet//libuchardet.a(uchardet.cpp.o):Infunction`uchardet_new':uchardet.cpp:(.text+0x19):undefinedreferenceto`operatornew(unsignedlong)'uchardet.cpp:(.text+0x3c):undefinedreferenceto`std::string::_Rep::_S_empty_rep_storag

c++ - 是否有任何理由避免使用 tmpnam() 来获取临时文件的名称?

我打算使用tmpnam()命名一个临时文件,稍后将重命名,而不是删除。但是我找到了以下文档,现在我对上面写的部分很感兴趣“...天真的程序员可能认为它是临时文件的合适名称。”来自http://man7.org/linux/man-pages/man3/tmpnam.3.htmlThetmpnam()functionreturnsapointertoastringthatisavalidfilename,andsuchthatafilewiththisnamedidnotexistatsomepointintime,sothatnaiveprogrammersmaythinkitasui